草庐IT

c++ - QML Qt openUrlExternally

全部标签

c++ - "<<"(双尖括号)在 C/C++ 枚举中是什么意思?

enumofp10_port_state{OFPPS10_STP_LISTEN=0 最佳答案 它是一个左移位运算符。这意味着它将位向左移动指定的位数:假设值为:0x0For000011110x0F在MicrosoftC++中,右移(>>)保留符号(或最重要的数字,最左边的数字)取决于数字是有符号还是无符号(假设一个字节的大小):signedinteger(anintforexample):0x80or100000000x80>>7=111111110x10or000100000x10>>4=00000001ifitsunsigned

c++ - 直观地解释指针及其意义?

我很难理解指针,尤其是函数指针,我希望有人能告诉我它们到底是什么以及它们应该如何在程序中使用。特别感谢C++中的代码块。谢谢。 最佳答案 indirection的概念理解这一点很重要。这里我们通过increment(x)传递值(注意创建和操作的是本地拷贝,而不是原始版本):在这里,通过increment(&x)指针(内存地址):请注意,引用与指针的工作方式类似,除了语法类似于值拷贝(obj.member)并且指针可以指向0(“空”指针)而引用必须指向非零内存地址。另一方面,函数指针让您可以像传递变量一样方便地传递和处理函数,从而在运

c++ - C/C++ : Converting hexadecimal value in char to integer

我将十六进制值存储为字符:charA='0';charB='6';charC='E';...我需要将它们转换为整数。我知道'atoi',但这只适用于十进制编码的字符值。有类似的功能吗? 最佳答案 intv=(A>'9')?(A&~0x20)-'A'+10:(A-'0');对于ASCII是正确的。对于其他字符集,类似的方法也行得通,但您需要使用toupper而不是&~0x20。 关于c++-C/C++:Convertinghexadecimalvalueinchartointeger,我们

c++ - 0x7FFF 和 32767 的类型有什么区别?

我想知道值0x7FFF和32767之间的区别是什么。据我所知,它们应该都是整数,唯一的好处是符号方便。它们将占用相同数量的内存,并以相同的方式表示,或者选择将数字写为0x而不是以10为基数还有其他原因吗? 最佳答案 唯一的好处是一些程序员发现在他们的头脑中更容易在16进制和二进制之间进行转换。由于每个以16为基数的数字正好占用4位,因此更容易将位对齐可视化。而且以2为基数写起来相当麻烦。 关于c++-0x7FFF和32767的类型有什么区别?,我们在StackOverflow上找到一个类

c++ - 为什么我会从这个 unsigned int 中得到段错误?

我正在尝试初始化一个整数数组并将所有元素设置为1。我需要该数组的上限为4294967295,或者32位unsignedint可能的最大数.这对我来说似乎是一项微不足道的任务,但我遇到了segfault。我可以空运行for循环,它似乎工作正常(虽然速度很慢,但它正在处理近43亿个数字,所以我不会提示)。当我尝试在循环中执行任何类型的操作时,问题似乎就出现了。我在下面的指令-primeArray[i]=1;-导致segfault错误。据我所知,这不应该导致我超出阵列。如果我注释掉该行,则不会出现segfault。已经很晚了,我疲倦的眼睛可能只是遗漏了一些简单的东西,但我可以再用一双。这是我

c++ - 为什么 python 中的普通循环运行起来比 C++ 中的循环慢得多?以及如何优化它?

这个问题在这里已经有了答案:WhyarePythonProgramsoftenslowerthantheEquivalentProgramWritteninCorC++?(11个答案)关闭9年前。简单地在python和C++中运行一个近空的for循环(如下),速度有很大的不同,python慢​​了一百多倍。a=0foriinxrange(large_const):a+=1inta=0;for(inti=0;i另外,我可以做些什么来优化python的速度?(补充:我在这个问题的第一个版本中举了一个不好的例子,我并不是说a=1以便C/C++编译器可以优化它,我的意思是循环本身消耗了大量资源

c++ - 如果我覆盖堆栈上的返回地址会怎样?

我知道这是危险的行为,但我想弄清楚发生了什么。代码如下:#include#includestaticintcount=0;voidhello(void){count++;fprintf(stderr,"hello!%d\n",count);}voidfoo(void){void*buf[10];staticinti;for(i=0;i结果如下:……hello!83hello!84hello!85hello!86hello!87hello!88hello!89Segmentationfault(coredumped)为什么hello函数被调用了89次?当函数foo返回时,pc寄存器应该得

c++ - 是否有预处理器定义来区分 gcc 和 g++ 代码?

是否有在gcc和g++编译器中定义的预处理器宏,以便如果我想让我的C代码链接到C标准库或C++标准库?像这样的东西:一些文件.c#ifdef__CPP__#include#else#include我确定有,但快速的Google搜索并没有立即指向我,我确定有人会发布重复的问题,但无论如何,请指出正确的方向。 最佳答案 在c++中你可以#ifdef__cplusplus例如,如果c++代码您希望编译器将某些代码片段作为c代码来处理,您需要将该代码块放入#ifdef__cplusplusextern"C"{#endif#ifdef__cp

c++ - uint32、int16、uint8 .. 为什么这些常用数据类型没有纳入标准

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion多年来,在涉及C/C++的多个组织和各种项目中,我发现通过定义本地版本的types.h解决了对固定宽度整数的需求,它看起来像这个:-typedefsignedcharint8;typedefunsignedcharuint8;typedefsignedshortint16;typedefunsignedshortuint16;typedefsignedlongint32;typedefun

c++ - c 和 c++ 中二维数组元素的类型是什么?

例如intarr[2][3]=...arr[0]的类型是int(*)[3]//pointertoint[3],whichisapointer.或者int[3]//anarraywhosesizeis3,whichisanarray.谷歌没有告诉我关于这个问题的任何信息。我知道指针和数组是不同的类型(派生类型)。可能C和C++的处理方式不同,希望能看到标准的写法。 最佳答案 arr[0]是int[3]类型,不是指针。int(*p)[3]属于int(*)[3]类型,表示指向包含3个元素的数组的指针。指针不是数组,数组也不是指针。现在,当